package com.itheima.reggie.mapper;

import com.itheima.reggie.dto.SetmealDto;
import com.itheima.reggie.entity.Setmeal;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Options;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;

import java.time.LocalDateTime;
import java.util.List;

public interface SetmealMapper {


    /*
     * 查询指定类别的套餐数量
     * */
    @Select("select count(*) from setmeal where category_id=#{categoryId} and is_deleted=0")
    Integer countByCid(Long categoryId);


    /*
     *保存套餐数据
     * */
    @Insert("insert into setmeal values(null,#{categoryId},#{name},#{price},#{status},#{code},#{description}," +
            "#{image},#{createTime},#{updateTime},#{createUser},#{updateUser},0) ")
    //插入后获取主键
    @Options(useGeneratedKeys = true, keyColumn = "id", keyProperty = "id")
    Integer save(SetmealDto setmealDto);


    /*
     * 根据套餐名称查询所有套餐数据(分页查询,第一条sql)
     * */
    List<Setmeal> findAll(@Param("name") String name);



    /*
    *查询指定id列表数据中含有启用套餐数据的个数
    * */
    Integer countByIds(@Param("ids") List<Long> ids);


    /*
    * 删除指定多个id的套餐(伪删除)
    * */
    Integer deleteByIds(@Param("ids") List<Long> ids,
                        @Param("updateUser") Long updateUser,
                        @Param("updateTime") LocalDateTime updateTime);


    /*
    * 通过套餐id查询一个id
    * */
    SetmealDto findById(Long id);


    /*
    * 根据id修改套餐
    * */
    Integer updateById(SetmealDto setmealDto);
}
